A Monadic Multi-stage Metalanguage
نویسندگان
چکیده
We describe a metalanguage MMML, which makes explicit the order of evaluation (in the spirit of monadic metalanguages) and the staging of computations (as in languages for multi-level binding-time analysis). The operational semantics of MMML is very intuitive and consists of two parts: local (semantic preserving) simplification rules, and steps of computation executed in a deterministic order (because they may have side-effects). The two parts can be changed independently: the first by adding datatypes and recursive definitions, the second by adding computational effects. We have focus on the computational aspects, rather than static error detection, thus the simple type system adopted, can detect the usual type errors, but not more subtle link errors, caused by the interplay between code generation and computational effects. Because of its explicit annotations, MMML is quite suitable as intermediate language and for equational reasoning. It is at least as expressive as MetaML (we provide a translation), but too verbose (in comparison to MetaML). The explicit separation of computational types from code types, makes clear the distinction between a computation for generating code and the generated code, and provides the basis for multi-lingual extensions, where a variety of programming languages coexist.
منابع مشابه
A Cumulative Monadic Metalanguage
We introduce a monadic metalanguage which combines two previously proposed monadic metalanguages: one for staging and the other for value recursion. The metalanguage includes also extensible records as a basic name management facility.
متن کاملA Fully Abstract Semantics for a Concurrent Functional Language with Monadic Types
This paper presents a typed higher-order concurrent functional programming language, based on Moggi’s monadic metalanguage and Reppy’s Concurrent ML. We present an operational semantics for the language, and show that a higherorder variant of the traces model is fully abstract for maytesting. This proof uses a program logic based on Hennessy– Milner logic and Abramsky’s domain theory in logical...
متن کاملCoherence of subsumption for monadic types
One approach to give semantics to languages with subtypes is by translation to target languages without subtyping: subtypings A B are interpreted via conversion functions A→B. This paper shows how to extend the method to languages with computational effects, using Moggi’s computational metalanguage.
متن کاملMonads and Adjunctions for Global Exceptions
In this paper, we look at two categorical accounts of computational effects (strong monad as a model of the monadic metalanguage, adjunction as a model of call-bypush-value with stacks), and we adapt them to incorporate global exceptions. In each case, we extend the calculus with a construct, due to Benton and Kennedy, that fuses exception handling with sequencing. This immediately gives us an ...
متن کاملStrong Normalization of Moggis's Computational Metalanguage
Handling variable binding is one of the main difficulties in formal proofs. In this context, Moggi’s computational metalanguage serves as an interesting case study. It features monadic types and a commuting conversion rule that rearranges the binding structure. Lindley and Stark have given an elegant proof of strong normalization for this calculus. The key construction in their proof is a notio...
متن کامل